# CSE 331 – Project 3

# Ozan Şelte – 161044061

## alu\_32\_msb\_tb:

Sums 2 32bit numbers. Numbers are hexadecimals.

# 001 22222222 + 33333333 = 55555555 # 001 12341234 + 66667777 = 789a89ab

### conc\_tb:

Concatenates 4 8bit numbers. Numbers are hexadecimals.

01,23,45,67 = 67452301

67,45,23,01=01234567

## ctrl\_unit\_tb:

| sign:0 | memW:0 | regW:1 | slct:00 | alu:001 | # op:20 |
|--------|--------|--------|---------|---------|---------|
| sign:1 | memW:0 | regW:1 | slct:00 | alu:001 | # op:24 |
| sign:0 | memW:0 | regW:1 | slct:01 | alu:001 | # op:21 |
| sign:1 | memW:0 | regW:1 | slct:01 | alu:001 | # op:25 |
| sign:1 | memW:0 | regW:1 | slct:10 | alu:001 | # op:0f |
| sign:1 | memW:0 | regW:1 | slct:11 | alu:001 | # op:23 |
| sign:1 | memW:1 | regW:0 | slct:00 | alu:001 | # op:28 |
| sign:1 | memW:1 | regW:0 | slct:01 | alu:001 | # op:29 |
| sign:1 | memW:1 | regW:0 | slct:11 | alu:001 | # op:2b |

## extender\_16\_32\_tb:

Extendes 16bit number to 32bit number.

 $\# \ zero \qquad \quad 1010 \ 1010 \ 1010 \ 1010 \quad \rightarrow \quad \quad 0000 \ 0000 \ 0000 \ 0000 \ 1010 \ 1010 \ 1010 \ 1010$ 

# sgnd 1010 1010 1010 1010  $\rightarrow$  1111 1111 1111 1010 1010 1010 1010

## extender\_upper\_tb:

 $\#\ 1010\ 1010\ 1010\ 1010\ \to \ 1010\ 1010\ 1010\ 1010\ 0000\ 0000\ 0000\ 0000$ 

## filler\_8\_32\_tb: & filler\_16\_32\_tb

Numbers are hexadecimals.

# ab  $\rightarrow$  000000ab # 20  $\rightarrow$  00000020

# abcd → 0000abcd # 2043 → 00002043

#### mux32 4 1 tb:

32bit 4:1 Multiplexer

# 00 11111111 # 01 55555555 # 10 aaaaaaaa # 11 eeeeeeee

## Mips32 Tests:

### **Initial Registers:**

#### **Initial Memory Data:**

M1: 1001 1111 1110 0000 1100 0001 1001 0001

#### **Instructions:**

| Operation | Opcode | RS    | RT    | IMM                 |
|-----------|--------|-------|-------|---------------------|
| LB        | 100000 | 00000 | 00010 | 0000 0000 0000 0001 |
| LB        | 100000 | 00001 | 00011 | 0000 0000 0000 0001 |
| LBU       | 100100 | 00000 | 00100 | 0000 0000 0000 0001 |
| LBU       | 100100 | 00001 | 00101 | 0000 0000 0000 0001 |
| LH        | 100001 | 00000 | 00110 | 0000 0000 0000 0001 |
| LH        | 100001 | 00001 | 00111 | 0000 0000 0000 0001 |
| LHU       | 100101 | 00000 | 01000 | 0000 0000 0000 0001 |

| LHU | 100101 | 00001 | 01001 | 0000 0000 0000 0001 |
|-----|--------|-------|-------|---------------------|
| LUI | 001111 | 00000 | 01010 | 0000 0000 0000 0001 |
| LUI | 001111 | 00001 | 01011 | 0000 0000 0000 0001 |
| LW  | 100011 | 00000 | 01100 | 0000 0000 0000 0001 |
| LW  | 100011 | 00001 | 01101 | 0000 0000 0000 0001 |
| SB  | 101000 | 00000 | 01001 | 0000 0000 0000 0011 |
| SB  | 101000 | 00001 | 01010 | 0000 0000 0000 0011 |
| SH  | 101001 | 00000 | 01011 | 0000 0000 0000 0101 |
| SH  | 101001 | 00001 | 01100 | 0000 0000 0000 0101 |
| SW  | 101011 | 00000 | 01101 | 0000 0000 0000 0111 |
| SW  | 101011 | 00001 | 01110 | 0000 0000 0000 0111 |

## **Outputs:**

Testbench modifies the registers and the memory. But it prints more than clocks.

#### **Registers:**

#### **Memory Data:**